## COL215 Assignment 1 Hardware Assignment Setup

## 1 One-time GCL setup for Vivado

To know whether the given system is old or new, run the following command in the terminal after login into your GCL account:

```
§ lsb release -a
```

If the Ubuntu version is 20.xx.x then you are using new system, otherwise you are working on the older machine.

Students who are using old systems in the DHD lab should follow the following instructions for vivado setup.

- Logon to the machine using your GCL account.
- In your home folder, open the .bashrc file in home folder (create if not already present). Use (gedit .bashrc) to open the file and add the lines below (create a new file if .bashrc doesn't exist):
  - § export XILINXD LICENSE FILE=2100@10.208.22.170:/extra/xilinxlic/Xilinx.lic
  - § source /opt/Xilinx/14.7/ISE DS/settings64.sh
  - § source /opt/Xilinx/Vivado/2016.4/settings64.sh
- Alternatively, you can add the alias below and whenever you open a shell, run the command "en-able\_xilinx":
  - § alias enable\_xilinx="export XILINXD\_LICENSE\_FILE=2100@10.208.22.170:/extra/xilinxlic/Xilinx.lic; source /opt/Xilinx/14.7/ISE DS/settings64.sh; source /opt/Xilinx/Vivado/2016.4/settings64.sh"
- After making changes to .bashrc, run "source .bashrc" in the terminal
- To run the required application, type **vivado** in the terminal.

Students working on the new systems don't need the license file and can directly log into their GCL account to start working on **vivado**.

- In your home folder, open the .bashrc file and add the following line (create a new file if .bashrc doesn't exist)
- § source /opt/Xilinx/Vivado/2022.1/settings64.sh
- After making changes to .bashrc, run "source .bashrc" in the terminal
- To run the required application, type **vivado** in the terminal.

## 2 Launching and creating a project in Vivado

- 1. To launch Vivado, type vivado in the terminal.
- 2. Once Vivado is launched logout and login to the system. This step is required only for the first time login.
- 3. Launch Vivado once again.
- 4. When the tool opens, click on Create New project and click Next.
- 5. Select the project directory and name.
- 6. In the next dialog box, select RTL project.



7. Create a new file named **AND\_gate.** Select the file type as VHDL. Ensure that Target and simulator language is VHDL.



- 8. In the next dialog window for adding constraints, add the provided basys3.xdc file using "Add Files".
- 9. Select part number xc7a35tcpg236-1 and click next. After this the project creation is done.

- 10. Under **design source**, double click **AND\_gate** file to open it in the editor and add the following code for the basic AND gate.
- 11. Truth table and implementation for AND gate is given below,

```
entity AND_gate is
   Port ( a : in STD_LOGIC;
        b : in STD_LOGIC;
        c : out STD_LOGIC);
end AND_gate;

architecture Behavioral of AND_gate is

begin
   c <= a and b;
end Behavioral;</pre>
```

12. **Simulation of the design**: Now to simulate your design you need to make a test bench and test your code.

Test Benches are used to test the correctness of the Design Under Test or DUT. They can be used to provide inputs to the design and observe the outputs

As a start, you can force the values of the inputs and observe their output in the waveform. Sample testbench is given for simulation of AND gate.

**Note:** Test Bench is only for simulation. Please do not run the implementation flow on it as introduced in the next steps.

```
-- AND_gate_tb.vhd (testbench)
library ieee;
use ieee.std_logic_1164.all;
-- No ports for this TB so entity is empty
entity AND_gate_tb is
end AND_gate_tb;
architecture tb of AND_gate_tb is
    -- In this TB modeling Style, the test bench instantiates the DUT as a component
    -- and passes the inputs from a separate VHDL process via signals
    component AND_gate
      Port ( a : in STD_LOGIC;
             b : in STD_LOGIC;
             c : out STD_LOGIC);
    end component;
    signal a, b : std_logic; -- inputs
    signal c : std_logic; -- outputs
```

```
begin
    -- connecting testbench signals with AND_gate.vhd
    UUT : AND_gate port map (a => a, b => b, c => c);

-- inputs
    -- 00 at 0 ns
    -- 01 at 20 ns, as b is 0 at 20 ns and a is changed to 1 at 20 ns
    -- 10 at 40 ns
    -- 11 at 60 ns
    a <= '0', '1' after 20 ns, '0' after 40 ns, '1' after 60 ns;
    b <= '0', '1' after 40 ns;
end tb;</pre>
```



13. You can change the signal value in the simulation window, (i) left click the signal value and select force constant, (ii) change the value under force constant and (iii) select the simulation time and press play. After running the simulation for the selected time, you can observe the change in output signal c in the waveform window (highlighted in the red box). Refer to video: https://drive.google.com/file/d/lozKwQ-5wwQQR7VayAWX1QrbPDb-SC65W/view?usp=sharing







14. Please disable AND gate tb.vhd, test bench after running the simulation.



- 15. Please disable AND gate tb.vhd, test bench after running the simulation.
- 16. Next under the **Constraints section**, edit the **basys3.xdc** file to connect the switches and LED to the declared port. In this module, switches V17 and V16 act as inputs to the gate and LED U16 as the output of the gate.

17. Under the Flow Navigator, Click on Run synthesis then Run implementation. Please open the synthesized design to analyze the output that is generated. Look at the resource utilization. Observe the number of LUTs used in your design.



(a) Additional info: Number of jobs can be increased depending upon the available cores. This may improve the running time. For now, use the default value given in the dialog box.



18. After this click on Generate Bitstream.

19. Once this is done, click on Open Hardware Manager => Open Target => Auto Connect. Ensure that basys3 board is connected to the system via micro-USB cable.



- 20. Click on **Program Device**. Make sure the correct bit file is selected.
- 21. Once the process is complete, toggle the bottom right corner switches (V16 and V17, the AND gate inputs). This should change the LED (LD0/U16) according to the AND gate logic.



22. After completing the simulation and testing of AND gate, the next task is to realize a two input OR and single input NOT gate using the same template. The second part of the assignment will be released next week.

## 3 Assignment Submission Instructions

General assignment instructions which need to be followed for each assignment. Only one partner needs to submit. Mention all team member names and entry IDs during the submission.

- $1. \ \, {\rm Name \ the \ submission \ file \ as \ entry Number 1\_entry Number 2.zip}$
- 2. Go to Gradescope
- 3. Upload the following files:
  - Source file (.vhd)
  - Constraint File (.xdc)

- Bit file (.bit)
- Report (.pdf) The report needs to state your design decisions, lab work, simulation snapshots, and synthesis report ( particularly resource counts: Flip-flops, LUTs, BRAMs, and DSPs)